// pages/home/home.js
Page({

    /**
     * 页面的初始数据
     */
    data: {
        tabs: [
            {
                name: '全部',
                tab: 'all'
            },
            {
                name: '精华',
                tab: 'good'
            },
            {
                name: '分享',
                tab: 'share'
            },
            {
                name: '问答',
                tab: 'ask'
            },
            {
                name: '招聘',
                tab: 'job'
            }
        ],
        tab: 'all',
        page: 1,
        topics: [],
        isRequest: false
    },

    // tab点击事件
    choseTab(e) {
        this.setData({
            tab: e.currentTarget.dataset.tab
        })
        this.getTopics('tab')
    },

    // 请求主题列表数据的接口
    getTopics(type) {
        this.data.isRequest = true
        wx.showLoading({
          title: '拼命加载中...',
        })
        wx.request({
          url: 'https://cnodejs.org/api/v1/topics?tab=' + this.data.tab + '&page=' + this.data.page,
          success: (res) => {
            if(type === 'tab') {
                this.setData({
                    topics: res.data.data
                })
            } else if(type === 'loadmore') {
                this.setData({
                    topics: [...this.data.topics,...res.data.data]
                })
            } else {
                type()
                this.setData({
                    topics: res.data.data
                })
            }
            wx.hideLoading()
            this.data.isRequest = false
          }
        })
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function (options) {
        this.getTopics('tab')
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function () {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow: function () {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide: function () {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload: function () {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {
        this.data.page = 1
        this.getTopics(() => {
            wx.stopPullDownRefresh()
        })
    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {
        if(!this.data.isRequest) {
            this.data.page++
            this.getTopics('loadmore')
        }
        
    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage: function () {

    }
})